package org.hot100.h198;

/**
 * @Author: wjy
 * @Date: 2022/1/10 17:05
 */
public class Solution {

    /**
     * 你是一个专业的小偷，计划偷窃沿街的房屋。每间房内都藏有一定的现金，影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统，如果两间相邻的房屋在同一晚上被小偷闯入，系统会自动报警。
     *
     * 给定一个代表每个房屋存放金额的非负整数数组，计算你 不触动警报装置的情况下 ，一夜之内能够偷窃到的最高金额。
     *
     * 示例 1：
     *
     * 输入：[1,2,3,1]
     * 输出：4
     * 解释：偷窃 1 号房屋 (金额 = 1) ，然后偷窃 3 号房屋 (金额 = 3)。
     *     偷窃到的最高金额 = 1 + 3 = 4 。
     *
     * 示例 2：
     *
     * 输入：[2,7,9,3,1]
     * 输出：12
     * 解释：偷窃 1 号房屋 (金额 = 2), 偷窃 3 号房屋 (金额 = 9)，接着偷窃 5 号房屋 (金额 = 1)。
     *     偷窃到的最高金额 = 2 + 9 + 1 = 12 。
     *
     * @param args
     */
    public static void main(String[] args) {

//        int[] ints = {2,7,9,3,1};
        int[] ints = {1,2,3,1,4};
        Solution solution = new Solution();

        System.out.println(solution.rob(ints));

    }

    public int rob(int[] nums) {

        // NB!!!!!!
        // dp[n] = Math.max(dp[n - 1], dp[n - 2] + nums[n])
        // dp[n + 1] = Math.max(dp[n], dp[n - 1] + nums[n + 1])
        // dp[n + 2] = Math.max(dp[n + 1], dp[n] + nums[n + 2])
        int a = 0, b = 0, sum = 0, temp = 0;
        for (int num : nums) {
            temp = sum;
            sum = Math.max(sum, b + num);
            b = temp;
        }

        return sum;

        // pre：记录当前值的上一个的上一个的值（如果没有为0）
        // tmp：记录当前值的上一个值（如果没有为0）
        // cur记录当前最大值
        /*int pre = 0, cur = 0, tmp;
        for(int num : nums) {
            tmp = cur;
            cur = Math.max(pre + num, cur);
            pre = tmp;
        }
        return cur;*/
    }

}
